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TITLE 

IMAGE PROCESSING APPARATUS AND METHOD, AND PRINTING 

METHOD AND APPARATUS 

Field of the Invention 

[0001] This invention relates to an image processing apparatus and method for 
inputting and processing multilevel image data, and to a printing method and 
apparatus for generating print data from this multilevel image data and printing the 
print data. 

BACKGROUND OF THE INVENTION 
[0002] When an image signal expressed by RGB signals, which are luminance 
signals, is entered and printed by a color printer, the image data is sent to the 
print e r upon must be[[ing]] converted to CMYK signals, which are density signals. 
When such a color conversion is made, color tones are corrected in such a manner 
that the original image signal represented by the RGB signals and the image as 
outputted by the printer, which of course must be printed using only those colors 
that are reproducible by the color printer will have similar tones. Furthermore, the 
CMYK signals corresponding to the original image signal are subjected to an 
output correction in such a manner that the density value of the image printed by 
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the color printer will exhibit a linear relationship with respect to the CMYK 
signals. Each item of CMYK data thus obtained and represented by multilevel data 
is quantized to reduce the number of tones to that capable of being printed by the 
color printer. 

[0003] Since the conversion equations used in such color conversion are 
high-order equations, the computations take a long time. For this reason, the 
general practice is to retain pre-calculated values in table form and perform the 
color conversion by referring to the table. If such a table is used, the input values 
thereto are discrete values represented by, e.g., eight bits each. As a consequence, 
the color conversion is not of the linear continuous type A and the actual output 
values include error. 

[0004] In the conventional color printer, deterioration of the image [[by]] due to 
accumulation of such error is almost negligible in the actually printed image 
because the printer resolution and reproducible tonality is not so are only 
moderately high. However, in images printed by the latest high-resolution, 
high-tonality color printers, such error affects the quality of the image and is no 
longer negligible. 

[0005] The present invention has been devised in view of the prior art described 
above* and its object is to provide an image processing apparatus and method for 
dividing entered multilevel image data into pixel blocks each composed of a 
plurality of pixels, and generating image data, which conforms to the entered 
multilevel image data, on a per-pixel-block basis. 

[0006] Another object of the present invention is to provide an image processing 
apparatus and method in which, when multilevel image data is converted using a 
table, the converted image data, which conforms to an input value, can be obtained 
in units of pixel blocks of the entered multilevel image data. 
[0007] According to the present invention, the foregoing objects are attained by 
providing an image processing apparatus for processing multilevel image data. 
That apparatus comprises dividing means for dividing the multilevel image data 
into pixel blocks each comprising a plurality of pixels. Conversion tables, each 
containing a plurality of items of conversion data, are provided, each item in which 
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corresponds to a pixel position in each pixel block obtained by operation of the 
dividing means. Conversion means refer to the conversion tables to convert multi- 
level image data of a pixel of each pixel block into (new, or converted) data 
corresponding to that pixel, and quantization means quantize the resulting data. 
Each item of the conversion data of each conversion table has been set in such a 
manner that an average value of the data corresponding to the pixel in the pixel 
block converted by the conversion means, takes on a value that is based on the 
multilevel image data within the block, for applying imag e processing to multilevel 
image data input the r eto, comprising : dividing m e ans for dividing the input 
multilevel image data into pixel blocks each comp r ising a plurality of pixels; 
conv e rsion tables having a plurality of items of conversion data, each of which is 
corresponding to a pixel position in each pixel block obtained by division by the 
dividing m e ans; and conve r sion means for conv e rting, by referring to the 
conve r sion tables, e ach item of pix e l data of e ach p ixel block obtained by division 
by the dividing means, into data corresponding to pixel data in the pix e l block; 
wherein the conversion data of each of the conversion tables has been set in such a 
manner that an average value of the data in e ach pixel block converted by the 
conversion means, takes on a value that is based on the pix e l data within the pix e l 
block. 

[0008] Further, according to the present invention, the foregoing objects are 
attained by providing an image processing method for applying image processing 
to multilevel image data applied as an inpu t. That method comprises dividing the 
multilevel image data into pixel blocks each comprising a plurality of pixels. 
Conversion tables, each containing a plurality of items of conversion data, are 
provided, each item in which corresponds to a pixel position in each pixel block. 
Those conversion tables are referred to, to convert multi-level image data of a pixel 
of each pixel block into (new, or converted) data corresponding to that pixel, and 
quantization means quantize the resulting data. Each item of the conversion data 
of each conversion table has been set in such a manner that an average value of the 
data corresponding to the pixel in the pixel block after conversion, takes on a value 
that is based on the multilevel image data within the block. , comprising: a dividing 
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step of dividing the input multilevel image data into pixel blocks each comprising a 
plurality of pixels; and a conv e rsion step of converting each item of pixel data of 
each pixel block obtained by division, by r efer r ing to conv er sion tables having a 
plurality of items of conv e rsion data, e ach corresponding to each p ixel p osition in 
each pix e l block obtained by division at said dividing step, into data co rr esponding 
to each pix e l in the block; wherein th e conv e rsion data of each of said conv e rsion 
tables has been set in such a manne r that an av e rag e valu e of th e data in each pixel 
block conv e rt e d at said conv e rsion ste p , takes on a value that is based on a 
co rre sponding pixel data within th e pix e l block. 

[0009] Other features and advantages of the present invention will be apparent 
from the following description taken in conjunction with the accompanying 
drawings, in which like reference characters designate the same or similar parts 
throughout the figures thereof. 

[0010] The accompanying drawings, which are incorporated in and constitute a 

part of the specification, illustrate an embodiment of the invention and, together 

with the description, serve to explain the principles of the invention. 

[0011] Fig. 1 is a block diagram illustrating the structure of an ink-jet printing 

system according to an embodiment of the present invention; 

[0012] Fig. 2 is a functional block illustrating the structure of an image processing 

unit in a printer driver according to this embodiment; 

[0013] Fig. 3 is a block diagram illustrating the structure of an ink-jet printing 
system according to an embodiment of the present invention; 
[0014] Fig. 4 is a perspective view illustrating the structure of the printing section 
of a serial-type inkjet printer according to this embodiment; 

[0015] Fig. 5A is a graph useful in describing gamma correction of an RGB signal 
and Fig. 5B a graph useful in describing a luminance-to-density conversion; 
[0016] Figs. 6A and 6B are diagrams useful in describing a comparison between 
an example of the prior art and this embodiment; 

[0017] Figs. 7A, 7B and 7C are diagrams useful in describing a specific example 
of an input correction according to this embodiment and an example of the prior 
art, in which Fig. 7A illustrates an example of input correction according to the 
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prior art, Fig. 7B illustrates a specific example of input correction according to this 
embodiment, and Fig. 7C is a diagram useful in describing the relationship 
between pixel positions and tables used; 

[0018] Fig. 8 is a graph useful in describing the relationship between an input 
signal and an output signal according to this embodiment; 

[0019] Figs. 9A and 9B are diagrams useful in describing a comparison between a 
specific example of output correction according to this embodiment and an 
example of the prior art; 

[0020] Figs. 1 OA and 10B are diagrams useful in describing a specific example of 
an output correction according to this embodiment and an example of the prior art; 
[0021] Figs. 1 1 A and 1 IB are diagrams useful in describing a comparison between 
a specific example of results of quantization according to this embodiment and an 
example of the prior art; 

[0022] Fig. 12 is a diagram useful in describing effects of an input correction and 
output correction according to this embodiment; 

[0023] Fig. 1 3 is a flowchart useful in describing image processing in a printer 
driver according to this embodiment; and 

[0024] Fig. 14 is a flowchart useful in describing processing in a tone correction 
unit according to another embodiment of the present invention. 
[0025] First, the features of the image processing . method and apparatus according 
to the preferred embodiments of the present invention will be described in brief. 
[0026] A block of input image data consisting of a plurality of pixels is adopted as 
a unit of which the tone is capable of being expressed, each of the plurality of items 
of pixel data constituting the unit is converted and the respective items of 
converted data are obtained in correspondence to each respective pixel data of the 
unit. An average value of these items of converted data in one unit is set so as to 
be different from the average value of other units in a case where the value (input 
value) of the pixel block comprising the original plurality of pixels is different 
from that of other pixel blocks. The data thus obtained by the conversion is then 
quantized to thereby be converted to values (C, M, Y and K components each 
represented by one bit, by way of example) conforming to the number of tones 
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[[of]] producible by the color printer^ and these values are sent to the printer so that 
they may be used in printing. 

[0027] In order to achieve this, input correction (conversion) tables corresponding 
to positions of respective ones of the plurality of pixels constituting the single unit 
(pixel block) are provided, and each item of pixel data within the single unit is 
converted using these input correction tables, whereby an image having a high 
tonality closer to that of the original image data can be printed. 
[0028] The image processing apparatus and method according to this embodiment 
may be implemented by a printer driver or the like installed in a host computer 
which generates print data output to a color printing apparatus such as an ink-jet 
printer. Alternatively, the apparatus and method may be implemented within a 
color printing apparatus of this type. The present invention is applicable not only 
to a printing apparatus such as a color printer but also to a high-resolution display 
or other image output apparatus as well as other image processing systems in 
which multilevel image data is processed to change the number of tones. 
[0029] Preferred embodiments of the present invention will be described with 
reference to the drawings. In the description that follows, it is assumed that image 
processing according to this embodiment is implemented by a printer driver 
installed in a host computer. However, the present invention is not limited to such 
an arrangement. 

[0030] Fig. 1 is a block diagram illustrating the general structure of an ink-jet 
printing system according to this embodiment. 

[0031] As shown in Fig. 1, the system includes an ink-jet printer 100 according to 
this embodiment. The printer 100 includes a printer engine 120 for printing an 
image according to the ink-jet method. The printer engine 120, which is that of a 
color printer, has a plurality of ink-jet heads that discharge ink corresponding to 
each of the colors of CMYK. These ink-jet heads are scanned back and forth to 
print an image on a sheet of printing material. The structure of ink-jet printer 100 
will be described later in detail with reference to Figs. 3 and 4. 
[0032] The system further includes a host computer 200 in which various 
application programs 220 and a printer driver 221 for the ink-jet printer 100 are 
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stored on a hard disk, not shown. The image processing method according to this 
embodiment may be implemented by the ink-jet printer 100 or by the printer driver 
221. The printer driver 221 is provided by the maker of the inkjet printer 100 in 
the form of a storage medium such as a CD-ROM and is installed on the hard disk 
of the host computer 200. When the printer driver 221 is to be run, it is loaded into 
a RAM 223 of the host computer 200 and executed under the control of a CPU 
222. 

[0033] The printer 100 receives print data sent from the printer driver 221 and 
prints an image by a specified printing method such as the multipass method. The 
inkjet printer 100 has mask information for deciding dot positions at which 
printing is performed on each scan. Dot positions (nozzles and printed dot 
positions) at which printing is performed on each pass are decided in accordance 
with the mask information. It should be noted that the mask information may be 
provided in the host computer 200 and that the printer 100 may be adapted so as to 
simply print based upon print data that has been received from the host computer. 
[0034] Fig. 2 is a block diagram illustrating an arrangement useful in describing 
image processing in the printer driver 22 1 of this embodiment. 
[0035] The arrangement of Fig. 2 includes an input correction unit 301 which 
inputs image data (luminance data), which is represented by R, G, B of eight bits 
each, from the application program 220, etc., refers to an input correction 
(conversion) table 113 and effects a conversion to, e.g., 8-bit data (density data) of 
each of C (cyan), M (magenta) and Y (yellow) used in printing. A tone correction 
unit 302 generates C, M, Y, K (black) data based upon the CMY data corrected by 
the input correction unit 301 and outputs the data thus generated. When printing is 
performed by the ink-jet printer 100, an output correction unit 303 decides the 
values of dat a, which arc to be printed on each pass, by referring to an output 
correction (conversion) table 117. Using, e.g., the error diffusion method, a 
quantizer 304 quantizes image data of eight bits of each of the components C, M, 
Y output from the output correction unit 303 and outputs 1-bit data (print data) for 
each of C, M, Y, K, which is the result of quantization. 
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[0036] Fig. 3 is a block diagram showing the basic structure of the ink-jet printer 
1 00 according the to an embodiment of the present invention. 

[0037] The printer includes a controller 101 for controlling the overall operation of 
the ink-jet printer according to this embodiment. A head driver 102 performs 
printing by driving an ink-jet head 105 based upon print data from the controller 
101. Motor drivers 103, 104 drive corresponding carriage and sheet-feed motors 
106, 107, respectively. An input unit 108 receives an input of image data from an 
external device such as the host computer 200 and supplies the image data to the 
controller 101. 

[0038] As for the structure of the controller 101, the latter includes a CPU such as 
a microprocessor, a program memory 111 for storing a program executed by the 
GPU 110, and a RAM 115 having a work area, which stores various data when the 
CPU 110 operates, and a print buffer 1 16 for storing print data. The controller 101 
further includes a print buffer controller (PBC) 112, which exercises control so as 
to extract print data, which is to be printed, from the print buffer 1 16; the input and 
output correction tables 113, 117; and mask data 1 14 used to decide data to be 
printed when the ink-jet head 105 is scanned. In a case where the above-described 
processing is executed by the printer driver 221, the correction tables 113, 117 
need not be provided in the ink-jet printer 100. 

[0039] Fig. 4 is a diagram useful in describing the structure of the printing section 
of the ink-jet printer 100 according to this embodiment of the present invention. 
[0040] As shown in Fig. 4, a head cartridge 205 is obtained by integrating an 
ink-jet head (105 in Fig. 3) and an ink supply source. The head cartridge 205 is 
secured to a carriage 206 by a retaining member 202. The carriage 206 is mounted 
so as to be slidable along a shaft 211. A belt 203 is wound about a pulley 109, 
which is mounted on the rotary shaft of the carriage motor 106, and about another 
pulley 109a. Part of the belt 203 is secured to the carriage 206. As a result, the 
carriage 206 can be moved back and forth along the shaft 21 1 by rotating the 
carriage motor 106. The inkjet head 105 on head cartridge 205 is driven via the 
head driver 102 (see Fig. 3) in accordance with print data in sync with scanning of 
the carriage 206, thereby discharging ink that makes it possible to print a desired 
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image on a printing sheet 209 wound about a platen 210 to form a printing surface. 
It should be noted that the platen 210 is driven into rotation by driving the 
sheet-feed motor 107. 

[0041] Print data to be printed is supplied from the controller 101 to the head 
cartridge 205 via a cable 207 and a terminal connected thereto. The head cartridge 
205 can be provided with one or a plurality of ink-jet heads depending on the 
colors of inks used. A home-position sensor 204 senses that the carriage 206 is at a 
home position. 

[0042] Reference will be had to Figs. 5A to Fig. 7C to describe a specific example 
of processing for converting RGB image signals in the input correction unit 301 to 
CMY signals. 

[0043] Fig. 5A is a graph useful in describing gamma correction of entered RGB 
signals., and Fig. 5B a graph useful in describing an example in which RGB signals 
are converted to CMY signals. 

[0044] Figs. 6A and 6B are diagrams useful in describing the difference between 
the conventional input correction and input correction of image data according to 
this embodiment. 

[0045] Fig. 6A is a diagram useful in describing input correction using an input 
correction table according to the prior art, and Fig. 6B is a diagram useful in 
describing input correction using input correction tables b to e (which correspond 
to input correction table 113 mentioned above) according to this embodiment. 
[0046] In Fig. 6A, input values "200", "199", "198" and "197" are converted to 
"12", "12", "13" and "13", respectively. Accordingly, even though the input 
values "199" and "200" are different from each other, the output values are both 
the same, i.e., "12". The same holds true when the input values are "197" and 
"198". 

[0047] By contrast, in this embodiment, as shown in Fig. 6B, the different types of 
input correction tables (b to e) in correspondence to pixel positions in a pixel block 
are used, and each pixel data in each pixel block is converted each data in 
accordance with each pixel position of the pixel block, as a single unit consisting to 
a pixel block comprising 2x2 pixels. 
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[0048] Specific examples are illustrated in Figs. 7 A to 7C. 
[0049] Fig. 7A is a diagram useful in describing a conventional input correction 
corresponding to Fig. 6A. This illustrates an example in which a block comprising 
2x2 pixels of entered RGB data is adopted as one unit and the pixel block is 
converted using the input correction table a. In this case, the values corresponding 
to each pixel block are converted to identical values regardless of the fact that the 
pixel data of the pixel blocks are different from one another, as shown in Fig. 6A. 
[0050] By contrast, in Fig. 7B relating to this embodiment, the input correction 
tables (b to e) used in the correction become different depending upon the pixel 
positions in the pixel block, as illustrated in Fig. 7C. As a result, in a pixel block 
unit comprising 2x2 pixels, the output values corresponding to the input values 
take on values that differ from one another depending upon differences in the input 
values, as shown in Fig. 7B. 

[0051] For example, compare Figs. 7A and 7B. The average values of blocks 701 
and 704, which correspond to the blocks in which all input pixel values are "200" 
and "197", respectively, do not change between Figs. 7A and 7B. However, in the 
case of block 702 for which the input pixel values are all "199", the average value 
in Fig. 7A is "12" whereas the average value in Fig. 7B is "12.25". Further, in the 
case of block 703 for which the input pixel values are all "198", the average value 
in Fig. 7A is "13" whereas the average value in Fig. 7B is "12.75". As a result, in 
the case of Fig. 7B, it will be understood that the average values of the converted 
blocks have been converted to values conforming to respective ones of the input 
values "197" to "200". 

[0052] A specific example of processing in the output correction unit 303 in which 
a CMYK signal is converted to data suited to the printer 100 will be described with 
reference to Figs. 8 to 1 0B. 

[0053] Fig. 8 is a graph illustrating the correction characteristic of output signal 
values (density data) versus input signal values (density data) in the output 
correction unit 303 according to this embodiment. 

[0054] Fig. 9A is a diagram useful in describing an output correction using the 
conventional output correction table f, and Fig. 9B is a diagram useful in 
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describing an output correction using output correction tables g to j (which 
correspond to the output correction table 117) according to this embodiment. 
[0055] In Fig. 9A, input values "15", "14", "13" and "12" are converted to "7", 
"7", "6" and "6", respectively. Accordingly, even though the input values "14" and 
"15" are different from each other, the output values are both the same, i.e., "7". 
The same holds true when the input values are "12" and "13". 
[0056] By contrast, in this embodiment, as shown in Fig. 9B, the different types of 
output correction tables (g to j) in correspondence to each pixel position of a pixel 
block are used, and each pixel data in each pixel block is converted in accordance 
with each pixel position in each pixel block, as a single unit constituting a pixel 
block comprising 2x2 pixels. 

[0057] Specific examples are illustrated in Figs. 10A and 10B. 
[0058] Fig. 10A is a diagram useful in describing a conventional output correction 
corresponding to Fig. 9A. This illustrates an example in which a block comprising 
2x2 pixels of entered CMYK data is adopted as one unit and the pixel block is 
converted using the output correction table f. In this case, the values corresponding 
to each pixel block are converted to identical values regardless of the fact that the 
input values are different from one another, as shown in Fig. 9 A. 
[0059] By contrast, in Fig. 10B relating to this embodiment, the output correction 
tables (g to j) used in the correction become different depending upon the pixel 
positions in the pixel block. As a result, in a pixel block unit comprising 2x2 
pixels, the output values corresponding to the input values take on values that 
differ from one another depending upon differences in the input values, as shown 
in Fig. 10B. 

[0060] For example, compare Figs. 10A and 10B. The average values of blocks 
801 and 804, which correspond to the blocks in which all input pixel values are 
"12" and "15", respectively, do not change between Figs. 10A and 10B. However, 
in the case of block 802 for which the input pixel values are all "13", the average 
value in Fig. 10A is "6" whereas the average value in Fig. 10B is "6.50". Further, 
in the case of block 803 for which the input pixel values are all "14", the average 
value in Fig. 10A is "7" whereas the average value in Fig. 10B is "6.75". As a 
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result, in the case of Fig. 10B, it will be understood that the average values of the 
converted blocks have been converted to values conforming to respective ones of 
the input values "12" to "15". 

[0061] In the prior art, therefore, as illustrated by the dotted line in Fig. 12, there 
are instances where the output values are the same even in a case where the input 
values differ. By contrast, according to this embodiment as indicated by the solid 
line in Fig. 12, when the pixel block units each containing a plurality of pixels are 
considered, the output values are converted to values that differ from one another 
in accordance with each of the input values. In other words, according to the 
present embodiment, the number of tones to be reproducible can be increased as 
shown in Fig. 12, in comparison with [[in]] the prior art. 

[0062] Figs. 1 1 A and 1 IB are diagrams illustrating an example of results obtained 
by quantizing the CMYK data of Figs. 10A and 10B, respectively. Fig. 1 1 A 
illustrates the results of quantization corresponding to Fig. 10A according to the 
prior art, and Fig. 1 IB illustrates the results of quantization corresponding to Fig. 
10B according to this embodiment. Here "7" has been adopted as the threshold 
value, so that values equal to or greater than "7" are converted (quantized) to "1" 
and values less than "7" are converted (quantized) to "0". The "1" data positions 
indicate pixel positions at which ink is printed by the ink-jet printer 100. 
[0063] It will be understood by referring to Figs. 10A, 10B and Figs. 1 1 A, 1 IB 
that even when the entered CMYK values are the same, this embodiment is more 
successful at distributing dots (data "1") conforming to the data values of each 
pixel block than in the prior art. In other words, data in an original pixel block is 
more reflected to an output image. As a result, Fig. 1 IB (embodiment) shows that 
more number of tones can be expressed in each pixel block in comparison with 
Fig. 1 1A (prior art). 

[0064] As a result, the embodiment is advantageous in that it is possible to 
reproduce tones which were not reproduced in the prior art and to reproduce a 
high-quality image in which the tones of the original image are preserved. 
[0065] Next, reference will be had to the flowchart of Fig. 13 to describe 
processing (image processing) for generating print data from input image data 
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(RGB) by the printer driver 221 of this embodiment. It should be noted that this 
processing may be executed by the ink-jet printer 100, as mentioned above. 
Further, the processing indicated by this flowchart can be applied similarly to the 
above-mentioned output correction processing described with reference to Figs. 
9 A, 9B and Figs. 10A, 10B. However, since the operation and description are 
substantially the same, the corresponding flowchart and its description are omitted. 
[0066] First, at step SI in Fig. 13, RGB image data (eight bits for each of R, G and 
B) is input from the application program 220. Control then proceeds to step S2, at 
which the input data is divided into pixel blocks each consisting of 2 x 2 pixels, by 
way of example. Next, at step S3, the above-described input correction tables b to 
e are applied to the pixels in each block in accordance with pixel positions in the 
block, respectively, to convert each item of pixel data (RGB data) of the pixel 
block to CMY values, as described earlier with reference to Fig. 7B. 
[0067] Control then proceeds to step S4, at which the CMY values are converted 
to CMYK values. Next, at step S5, the output correction tables g to j are applied to 
each of the pixel values (CMYK values) of each block, as described above with 
reference to Fig. 10B, whereby the corrected output CMYK values (eight bits for 
each of C, M, Y and K) is obtained. 

[0068] This is followed by step S6, at which the 8-bit corrected outputs C, M, Y, 
K are quantized as by the error diffusion method, thereby achieving a conversion to 
1-bit data (print data) conforming to the tones printable by the ink-jet printer 100. 
Next, at step S7, the 1-bit data obtained by the conversion is output to the printer 
1 00 and is printed thereby. 

[0069] In the embodiment, the input correction tables and the output correction 
tables are provided in correspondence to pixel positions in a pixel block and are 
used to convert pixel data in accordance with each pixel position and pixel data in 
the pixel block, therefore they are generally called as "a conversion table" in the 
embodiment. 

[0070] In the embodiment described above, the tone correction unit 302 of Fig. 2 
receives an input of 8bit data for each of C, M and Y and outputs 8-bit data for 
each of C, M, Y and K. However, there are instances where the number of tones in 
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the tone correction unit 302 is reduced. For example, the color blue is obtained by 
mixing the colors of cyan and magenta. However, if cyan and magenta are mixed 
in equal proportions, the resulting blue takes on a violet tinge and it is therefore 
necessary to reduce the amount of magenta mixed in. Color presented on a display 
using RGB data and color printed on a printing medium using CMYK data will 
have a different tint. 

[0071] This makes it necessary to perform the above-mentioned correction of 
color tone. Since the items of RGB data and CMYK data both are represented by 
finite discrete values, a decline in number of colors occurs owing to the correction 
of color tone. Such a decline in number of colors can be suppressed by adopting a 
method similar to that of the input or output correction. 
[0072] The following method is conceivable as a method of suppressing the 
decline in number of tones in the tone correction unit 302. 

[0073] Fig. 14 is a flowchart illustrating processing in the tone correction unit 302 
according to another embodiment of the present invention. 
[0074] First, at step SI 1 in Fig. 14, 8-bit data of each of the colors C, M, Y that 
have entered from the input correction unit 301 is converted to 16-bit data. This 
followed by step SI 2. Since error is initially "0", control proceeds directly from 
step S12 to step SI 3, where computation for correction of color tone is executed. 
The 16-bit data of each of the calculated colors C, M, Y, K is separated into 
integral and decimal parts and each part is made 8 -bit data (step S14). At step S12 
above, error that has occurred at step S14 is added to the pixel to be processed 
next. Step S 14 is followed by step Srt4 S15, at which it is determined whether the 
processing of all pixels has been completed. In order that the error developed at 
step S14 will be distributed to the pixels neighboring the pixel currently 
undergoing processing, the addition operation at step S12 is repeated until a "YES" 
decision is rendered at step SI 5. 

[0075] Thus, a decline in the number of tones of the 8-bit data of each of C, M, Y 
can be prevented in the calculation for tone correction, which is for correcting for a 
difference in tint between color displayed on a screen by RGB data and color 
printed on a printing medium by CMYK data. 
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[0076] The present invention is described in regard to a printing apparatus 
particularly of the ink-jet printing type, in which the apparatus is equipped with 
means (e.g., an electrothermal transducer or laser beam mechanism) for generating 
thermal energy as the energy utilized to discharge ink, wherein a change in the state 
of the ink is brought about by this thermal energy. For example, effects similar to 
those described above are obtained with a piezoelectric-type ink-jet printing 
method of the kind described in the specification of Japanese Patent Publication 
No. 6-6357. High-density, high-definition printing can be achieved in accordance 
with this method. 

[0077] With regard to a typical configuration and operating principle, it is 
preferred that the foregoing be achieved using the basic techniques disclosed in the 
specifications of USP 4,723,129 and 4,740,796. This scheme is applicable to both 
so-called on-demand-type and continuous-type apparatus. In the case of the on- 
demand type, at least one drive signal, which provides a sudden temperature rise 
that exceeds that for film boiling, is applied, in accordance with printing 
information^ to an electrothermal transducer arranged to correspond to a sheet or 
fluid passageway holding a fluid (ink). As a result, thermal energy is produced in 
the electrothermal transducer to bring about film boiling on the thermal working 
surface of the ink-jet head. Accordingly, air bubbles can be formed in the fluid 
(ink) in one-to-one correspondence with the drive signals. Owing to growth and 
contraction of the air bubbles, the fluid (ink) is jetted via an orifice so as to form at 
least one droplet. If the drive signal has the form of a pulse, growth and 
contraction of the air bubbles can be made to take place rapidly and in appropriate 
fashion. This is preferred since it will be possible to achieve fluid (ink) discharge 
exhibiting excellent response. 

[0078] Signals described in the specifications of USP 4,463,359 and 4,345,262 are 
suitable as drive pulses having this pulse shape. It should be noted that even better 
printing can be performed by employing the conditions described in the 
specification of USP 4,313,124, which discloses an invention relating to the rate of 
increase in the temperature of the abovementioned thermal working surface. 
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[0079] In addition to the combination of the orifice, fluid passageway and 
electrothermal transducer (in which the fluid passageway is linear or right-angled) 
disclosed as the construction of the print head in each of the above-mentioned 
specifications, an arrangement using the art described in the specifications of USP 
4,558,333 and 4,459,600, which disclose elements disposed in an area in which the 
thermal working portion is curved, may be employed. Further, it is possible to 
adopt an arrangement based upon Japanese Patent Application Laid-Open No. 
59-123670, which discloses a configuration having a common slot for the ink 
discharge portions of a plurality of electrothermal transducers, or Japanese Patent 
Application Laid-open No. 59-138461, which discloses a configuration having 
openings made to correspond to the ink discharge portions, wherein the openings 
absorb pressure waves of thermal energy. 

[0080] As a print head of the full-line type having a length corresponding to the 
maximum width of the printing medium capable of being printed on by the printing 
apparatus, use can be made of an arrangement in which the length is satisfied by a 
combination of plural print heads of the kind disclosed in the foregoing 
specifications, or an arrangement in which print heads serve as a single integrally 
formed print head. 

[0081] The print head may be of the replaceable tip-type, in which the electrical 
connection to the apparatus proper and the supply of ink from the apparatus proper 
can be achieved by mounting the head on the apparatus proper, or of the cartridge 
type, in which the print head itself is integrally provided with an ink tank. 
[0082] In order to make the effects of printing much more stable, it is preferred 
that the printing apparatus of the present invention be additionally provided with 
print head recovery means and auxiliary means, etc. Specific examples are print 
head capping means, cleaning means, pressurizing or suction means, preheating 
means comprising an electrothermal transducer, a heating element separate from 
this transducer or a combination of the transducer and the heating element, and a 
pre-discharge mode for performing a discharge of ink separate from a discharge for 
printing. These expedients are effective in achieving stable printing. 
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[0083] A printing apparatus according to the present invention may take [[on]] a 
variety of forms. It may be provided as an integral part of or separate from an 
information processing device such as a computer and serve as the image output 
terminal thereof, as a copier apparatus in combination with a reader or the like, or 
as a facsimile machine having sending and receiving functions. 
[0084] The present invention can be applied to a system constituted by a plurality 
of devices (e.g., a host computer, interface, reader, printer, etc.) or to an apparatus 
comprising a single device (e.g., a copier or facsimile machine, etc.). 
[0085] Further, it goes without saying that the object of the invention [[is]] can be 
attained by supplying a storage medium storing the program codes of the software 
for performing the functions of the foregoing embodiments to a system or an 
apparatus, reading the program codes with a computer (e.g., a CPU or MPU) of the 
system or apparatus from the storage medium, and then executing the program 
codes. 

[0086] In this case, the program codes read from the storage medium implement 
the functions of the above-described embodiments, and the storage medium storing 
the program codes constitutes the invention. 

[0087] Further, the storage medium, such as a floppy disk, hard disk, optical disk, 
magneto-optical disk, CD-ROM, CD-R, magnetic tape, non-volatile type memory 
card or ROM can be used to provide the program codes. 

[0088] Furthermore, besides the case where the aforesaid functions according to 
the embodiments are implemented by executing the program codes read by a 
computer, it goes without saying that the present invention covers a case where an 
operating system or the like running on the computer performs a part of or the 
entire process in accordance with the designation of program codes and 
implements the functions according to the above-described embodiments. 
[0089] It goes without saying that the present invention further covers a case 
where, after the program codes read from the storage medium are written in a 
function expansion board inserted into the computer or in a memory provided in a 
function expansion unit connected to the computer, a CPU or the like contained in 
the function expansion board or function expansion unit performs a part of or the 
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entire process in accordance with the designation of program codes and 
implements the function of the above embodiment. 

[0090] The present invention is not limited to the above embodiments and various 
changes and modifications can be made within the spirit and scope of the present 
invention. Therefore, to apprise the public of the scope of the present invention, 
the following claims are made. 
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